<template>
  <div
    class="fixed top-0 left-0 w-screen h-screen text-xl bg-slate-200 z-30 backdrop-blur-4xl bg-transparent pb-2 overflow-y-auto xl:p-2"
  >
    <!-- 移动端下的 navbar -->
    <m-navbar v-if="isMobileTerminal" sticky>
      {{ pexelData.title }}

      <template #right>
        <m-svg-icon
          name="share"
          class="w-3 h-3"
          fillClass="fill-zinc-200"
        ></m-svg-icon>
      </template>
    </m-navbar>
    <!-- pc端下 -->
    <m-svg-icon
      v-else
      name="close"
      class="w-3 h-3 ml-1 p-0.5 cursor-pointer duration-200 rounded-sm hover:bg-zinc-100 absolute right-2 top-2"
      fillClass="fill-zinc-400"
      @click="onPop"
    ></m-svg-icon>

    <!-- 内容区 -->
    <div
      v-if="pexelData.title"
      class="xl:w-[80%] xl:h-full xl:mx-auto xl:rounded-lg xl:flex"
    >
      <img
        class="w-screen mb-2 xl:w-3/5 xl:h-full xl:rounded-tl-lg xl:rounded-bl-lg"
        :src="pexelData.photo"
      />
      <div
        class="xl:w-2/5 xl:h-full xl:bg-white xl:dark:bg-zinc-900 xl:rounded-tr-lg xl:rounded-tb-lg xl:p-3"
      >
        <!-- pc端下收藏 分享 -->
        <div v-if="!isMobileTerminal" class="flex justify-between mb-2">
          <!-- 分享 -->
          <m-svg-icon
            name="share"
            class="p-1 w-4 h-4 cursor-pointer hover:bg-zinc-200 dark:hover-zinc-200 duration-300 rounded"
          ></m-svg-icon>
          <!-- 收藏 -->
          <m-button
            type="info"
            icon="heart"
            iconClass="fill-zinc-900 dark:fill-zinc-200"
          ></m-button>
        </div>
        <!-- 标题 -->
        <p
          class="text-base text-zinc-900 dark:text-zinc-200 ml-1 font-bold xl:text-xl xl:mb-5"
        >
          {{ pexelData.title }}
        </p>
        <!-- 作者 -->
        <div class="flex items-center mt-1 px-1">
          <img v-lazy :src="pexelData.avatar" class="w-3 h-3 rounded-full" />
          <span class="text-base text-zinc-900 dark:text-zinc-200 ml-1">{{
            pexelData.author
          }}</span>
        </div>
      </div>
    </div>
  </div>
</template>

<script setup>
import { ref } from 'vue'
import { getPexelsFromId } from '@/api/pexels.js'
import { isMobileTerminal } from '@/utils/flexible.js'
import { useRouter } from 'vue-router'

const router = useRouter()
const props = defineProps({
  id: {
    type: String,
    required: true
  }
})

const pexelData = ref({})
const getPexelData = async () => {
  const res = await getPexelsFromId(props.id)
  pexelData.value = res
}
getPexelData()

/**
 * 关闭
 */
const onPop = () => {
  // 移动端下跳转的类型
  store.commit('app/changeRouterType', 'back')
  router.back()
}
</script>

<style lang="scss" scoped></style>
